草庐IT

C++11 线程 : sleep for a remaining time

全部标签

html - Buffalo v0.11.0 与 flash 和 application.html 有问题吗?

我是Golang和Buffalo的初学者。我正在尝试使用https://github.com/gobuffalo/authrecipe中的authrecipe创建密码身份验证服务.但是,在尝试使用buffalodev运行它时,我从JSON转储中收到以下错误:ERRO[2018-05-10T14:20:48-04:00]application.html:line14:_flash.html:第3行:flash:未知标识符content_type=text/htmldb="0s"duration="5.354757ms"human_size="0B"method=GETparams="{}

go - 如何使变量成为线程安全的

我是Go的新手,我需要创建一个线程安全的变量。我知道在Java中您只能使用synchronized关键字,但是go中似乎不存在这样的内容。有什么方法可以同步变量? 最佳答案 Java中的synchronized是仅允许单个线程(在任何给定时间)执行代码块的方法。在Go中,有许多构造可以实现该目标(例如mutt,channel,waitgroups,sync/atomic中的原语),但是Go的谚语是:“不要通过共享内存进行通信;而是通过通信来共享内存。”因此,与其锁定和共享变量,不如不要这么做,而要在goroutines之间传递结果,

multithreading - 阅读缓存DIY书时的一个Go map线程安全问题

我正在读一本书,它教我如何编写像Redis这样的简单缓存。以实现分布式哈希为目标,项目必须有key迁移,这需要一个迭代器。而且我认为可能存在一些问题。他的书是关于迭代map的,但是在迭代的同时,读取锁的保持不是连续的。原因是尽量不影响主缓存进程。我相信一定存在线程安全问题,因为主缓存线程仍在写入映射。我写了一个演示,但不确定。//bookcodetypeinMemoryScannerstruct{pairpairChan*paircloseChchanstruct{}}func(c*inMemoryCache)NewScanner()Scanner{pairCh:=make(chan*

go - 如何使用vscode调试go 1.11.x

我是golang的新手,但正在开发go1.11.x。我的团队使用gomodule。第一次克隆存储库时,我需要运行GO111MODULE=ongomoddownload来下载依赖模块。然后我需要运行GO111MODULE=ongorunmain.go来运行我的应用。没有人使用vscode调试器,他们更喜欢控制台日志。有什么方法可以使用vscode调试go1.11.x吗?谢谢。 最佳答案 我现在找到了根本原因。这是我团队的源代码,与vscode或go1.11无关。我的工作launch.json在这里{"version":"0.2.0",

google-app-engine - app.yaml api_version 将 Google AppEngine 从 Go 1.9 迁移到 Go 1.11 时出现问题

在$DAYJOB,我们使用基于Go1.9的AppEngine应用程序。现在Google正在弃用1.9版,我正尝试使用migrationguide升级到1.11。.它说我应该设置runtime:go111并从app.yaml中删除api_version:go1.9值,但是这样做时,我获取部署错误消息:ERROR:(gcloud.app.deploy)Stagingcommand[/usr/lib/google-cloud-sdk/platform/google_appengine/go-app-stager/home/peter/src/licensemanager/src/web/ap

google-app-engine - Golang、App Engine、 channel 和线程安全

http://blog.golang.org/go-and-google-app-engine“此外,尽管存在goroutine和channel,但当Go应用程序在AppEngine上运行时,在给定实例中仅运行一个线程。也就是说,所有goroutine都在单个操作系统线程中运行,因此没有CPU并行性可用于给定的客户请求。我们希望在某个时候可以取消此限制”那是在2011年5月。现在仍然如此吗?我有一个应用程序,它除了利用Golang的速度之外什么都不做;获取一些输入数据,对其执行内存计算,返回结果。切勿接触数据存储区或任何其他AppEngineAPI。我需要应用程序执行许多计算,最好是具

memory - 为什么使用单独的线程原子操作更快?

我有两段代码,桌面上有32个内核。代码A使用32个线程并执行以下操作,1)将值写入内存中的一些随机位置2)原子地向全局变量添加一个值。代码B使用16个线程将值写入随机位置,并使用另外16个线程以原子方式将值添加到全局变量。我想知道为什么代码B在每秒对全局变量执行多少原子操作方面更快。这里是代码Avarauint64=0constN=10*1024*1024vardata[N]uint64funcmain(){fori:=0;i这里是代码Bvarauint64=0constN=10*1024*1024vardata[N]uint64funcmain(){fori:=0;i

go - Kafka 0.11/Golang Sarama 版本支持

我花了一些时间发现连接到Kafka0.11集群的Go应用程序使用的是旧的0.8.2版本的库,它在响应中缺少时间戳值。然后我发现不支持Kafka0.11.xAPI/版本(但他们正在努力)。我现在有两个解决方案。首先是在我的应用程序中明确设置所需的版本。其次是“调整”Sarama代码以使用版本0.10.x作为最低版本,使我能够使用所有0.10.xAPI/功能。我还在想为什么版本不是从我正在连接的Kafka代理中获取的?我无法从代码中理解它应该如何工作...我清楚地看到在sarama.Config.Version中设置或定义的版本,但我无法在连接后找到任何更新此值的内容给经纪人?我知道Pyt

go - 将 Golang1.11 与模块一起使用时,Protobuf 导入 "cannot find file"

我使用的是支持模块的Golang1.11,所以我的项目没有放入$GOPATH我想编译proto文件,我的文件结构我的TaskInfo.protosyntax="proto3";packagechaochaogege.filecatcher.common;optiongo_package="common";import"chaochaogege.com/filecatcher/common/ChunkInfo.proto";messageTaskInfo{stringname=1;stringstorePath=2;uint32workersNum=3;uint32totalSize=4

google-app-engine - 如何使用 go 模块在 GAE SE Go 1.11 上导入私有(private)存储库?

我在github上有一个go库包仓库作为私有(private)仓库。我写了一个像下面这样的项目来导入上面的库包。packagemainimport"github.com/foo/libpackage"funcmain(){:}这是目录层次结构。path/to/project|-main.go|-go.mod`-go.sum部署时出现错误,无法解决go:github.com/foo/libpackage@v0.0.0-20181127123728-008fddddc190:gitfetch-foriginrefs/heads/*:refs/heads/*refs/tags/*:refs/